<template>
  <div class="login-container">
    <!--
      el-form 表单组件
      每个表单项都必须使用 el-form-item 组件包裹
     -->

    <div class="login-form-wrap">
      <div class="login-head">
        <div class="logo"></div>
      </div>
      <!--
        配置 Form 表单验证：
        1、必须给 el-from 组件绑定 model 为表单数据对象
        2、给需要验证的表单项 el-form-item 绑定 prop 属性
           注意：prop 属性需要指定表单对象中的数据名称
        3、通过 el-from 组件的 rules 属性配置验证规则
          具体的验证规则可以参考：https://github.com/yiminghe/async-validator
          如果内置的验证规则不满足，也可以自定义验证规则
        手动触发表单验证：
        1、给 el-form 设置 ref 起个名字（随便起名，不要重复即可）
        2、通过 ref 获取 el-form 组件，调用组件的 validate 进行验证
       -->
      <el-form
        class="login-form"
        ref="login-form"
        :model="user"
        :rules="formRules"
      >
        <el-form-item prop="phone">
          <el-input
            v-model="user.phone"
            placeholder="请输入手机号"
          ></el-input>
        </el-form-item>
        <el-form-item prop="password">
          <el-input
            v-model="user.password"
            placeholder="请输入密码"
            type="password"
          ></el-input>
          <div style="font-size: 5px; color: #99a9bf" >没有账号?点击
            <span style="color: coral"><router-link to="/register" style="text-decoration: none">注册</router-link></span>
            <el-checkbox v-model="user.remember" style="float:right;">记住我</el-checkbox>
          </div>
        </el-form-item>
        <el-form-item prop="agree">
          <el-checkbox v-model="user.agree">我已阅读并同意用户协议和隐私条款</el-checkbox>
        </el-form-item>
        <el-form-item>
          <el-button
            class="login-btn"
            type="primary"
            :loading="loginLoading"
            @click="onLogin"
          >登录</el-button>
        </el-form-item>
        <span><router-link class="lost-password" to="/register">忘记密码</router-link></span>
      </el-form>
    </div>
  </div>
</template>

<script>
// 按需导入
import { getUserByPhone, login } from '@/api/user'
// 非组件模块可以这样加载使用 element 的 message 提示组件
import { Message } from 'element-ui'

export default {
  name: 'LoginIndex',
  components: {},
  props: {},
  data () {
    return {
      user: {
        phone: window.localStorage.getItem('phone') || '15279586728', // 登录手机号
        password: 'xiaohong', // 密码
        agree: true, // 是否同意协议
        remember: false // 是否记住密码
      },
      // checked: false, // 是否同意协议的选中状态
      loginLoading: false, // 注册的 loading 状态
      formRules: { // 表单验证规则配置
        // 要验证的数据名称：规则列表[]
        phone: [
          // trigger 用来配置触发校验的时机，有两个选项，change 是当输入的内容发送变化的时候，blur 当失去焦点的时候
          // pattern 表示通过正则表达式来验证
          { required: true, message: '请输入手机号', trigger: 'blur' },
          // { min: 4, max: 12, message: '用户名的长度为4到12位哦~', trigger: 'blur' }
          { pattern: /^1[3|5|7|8|9]\d{9}$/, message: '请输入正确的号码格式', trigger: 'blur' }
        ],
        password: [
          {
            required: true,
            message: '请输入密码',
            trigger: 'blur'
          },
          // \d表示6位
          {
            min: 8,
            max: 49,
            message: '密码长度不得小于8位哦~',
            trigger: 'blur'
          }
        ],
        agree: [
          {
            // 自定义校验规则：https://element.eleme.cn/#/zh-CN/component/form#zi-ding-yi-xiao-yan-gui-ze
            // 验证通过：callback()
            // 验证失败：callback(new Error('错误消息'))
            // validator 验证函数不是你来调用的，而是当 element 表单触发验证的时候它会自己内部调用
            // 所以你只需要提供校验函数处理逻辑就可以了
            //   通过：callback()
            // value是选择的值
            validator: (rule, value, callback) => {
              if (value) {
                // 验证通过
                callback()
              } else {
                // 验证失败
                callback(new Error('请勾选同意用户协议'))
              }
            },
            trigger: 'blur'
          }
        ]
      }
    }
  },
  computed: {},
  watch: {},
  created () {},
  mounted () {
  },
  methods: {
    onLogin () {
      // 获取表单数据（根据接口要求绑定数据）
      // const user = this.user

      // 表单验证
      // validate 方法是异步的
      this.$refs['login-form'].validate(valid => {
        // 如果表单验证失败，停止请求提交
        if (!valid) {
          return
        }

        // 验证通过，请求注册
        // 把登录名存储起来，如果注册成功需要用它来查询用户信息
        window.localStorage.setItem('phone', this.user.phone)
        this.login()
      })
    },

    login () {
      // 开启登陆中 loading...
      this.loginLoading = true

      // 对于代码中的请求操作
      // 1、接口请求可能需要重用
      // 2、实际工作中，接口非常容易变动，改起来麻烦
      // 我们建议的做法是把所有的请求都封装成函数然后统一的组织到模块中进行管理
      // 这样做的好处就是：管理维护更方便，也好重用
      login(this.user).then(res => {
        const status = res.data.code
        const message = res.data.message
        if (status === 20000) {
          // 登录成功
          this.$message({
            message: '登录成功',
            type: 'success'
          })
          // 将接口返回的用户相关数据放到本地存储，方便应用数据共享
          // 本地存储只能存储字符串
          // 如果需要存储对象、数组类型的数据，则把他们转为 JSON 格式字符串进行存储

          // 保存令牌
          window.sessionStorage.setItem('accessToken', res.data.data.body.access_token)
          // this.$store.commit('updateAccessToken', res.data.data.body.access_token)

          this.getInfo()

          // 跳转到首页
          // this.$router.push('/')

          this.$router.push({
            name: 'home'
          })
        } else {
          // 其他错误
          Message({
            type: 'warning',
            message: message
          })
        }
        // 关闭 loading
        this.loginLoading = false
      }).catch(err => { // 登录失败
        console.log('登录失败', err)
        this.$message.error('登录失败')

        // 清空Vuex
        this.$store.commit('cleanUser')

        // 关闭 loading
        this.loginLoading = false
      })
    },
    getInfo () {
      // 发送请求查询用户信息
      getUserByPhone(window.localStorage.getItem('phone')).then(res => {
        if (res.data.code === 20000) {
          // 获取用户信息成功
          this.$message({
            message: res.data.message,
            type: 'success'
          })
          // 判断用户是否选择保存用户名和密码
          console.log('是否记住密码：' + this.user.remember)
          if (this.user.remember) {
            window.localStorage.setItem('password', res.data.data.password)
          }
          // 使用vuex保存用户信息
          // this.$store.commit('updataAll', res.data)
          this.$store.commit('updateUserAll', res.data.data)
        } else {
          // 其他错误
          Message({
            type: 'warning',
            message: res.data.message
          })
        }
      }).catch(err => { // 登录失败
        console.log('获取用户信息失败', err)
        this.$message.error('登录失败')
      })
    }
  }
}
</script>

<style scoped lang="less">
.login-container {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  display: flex;
  // fixed默认是水平排列，这里设置成垂直排列
  flex-direction: column;
  //水平居中
  justify-content: center;
  //垂直居中
  align-items: center;
  background: url("./login_bg.jpg") no-repeat;
  // 背景填充模式 cover: 短边完全显示 contain: 长边完全显示
  background-size: cover;
  .login-form-wrap {
    min-width: 300px;
    padding: 30px 50px 10px;
    background-color: #fff;
    .login-head {
      display: flex;
      justify-content: center;
      .logo {
        width: 200px;
        height: 57px;
        background: url("./logo_index.png") no-repeat;
        background-size: contain;
      }
    }
    .login-form {
      .login-btn {
        width: 100%;
      }
    }
  }
}
  .lost-password {
    width: 55px;
    height: 20px;
    float: right;
    margin-bottom: 5px;
    margin-right: 0px;
    color: #99a9bf;
    font-size: 5px;
    text-decoration: none;
  }
</style>
